package com.feiyuan.core.utils;

import com.feiyuan.core.pojo.entity.SysQuartzJob;
import com.feiyuan.core.pojo.entity.SysQuartzJobLog;
import com.feiyuan.core.service.SysQuartzJobLogService;
import org.apache.commons.lang3.StringUtils;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.quartz.QuartzJobBean;

import java.lang.reflect.Method;
import java.time.LocalDateTime;


/**
 * 定时任务
 *
 * @author Mark sunlightcs@gmail.com
 */
public class ScheduleJob extends QuartzJobBean {
	private Logger logger = LoggerFactory.getLogger(getClass());

    @Override
    protected void executeInternal(JobExecutionContext context) throws JobExecutionException {
        SysQuartzJob scheduleJob = (SysQuartzJob) context.getMergedJobDataMap()
        		.get(SysQuartzJob.JOB_PARAM_KEY);
        
        //获取spring bean
        SysQuartzJobLogService scheduleJobLogService = (SysQuartzJobLogService) SpringContextUtils.getBean("quartzJobLogService");
        
        //数据库保存执行记录
		SysQuartzJobLog log = new SysQuartzJobLog();
        log.setJobId(scheduleJob.getId());
		log.setBeanName(scheduleJob.getJobClassName());
		log.setParams(scheduleJob.getParameter());
		log.setCreateTime(LocalDateTime.now());

        //任务开始时间
        long startTime = System.currentTimeMillis();
        
        try {
            //执行任务
        	logger.debug("任务准备执行，任务ID：" + scheduleJob.getId());

			Object target = SpringContextUtils.getBean(scheduleJob.getJobClassName());
			Method method = target.getClass().getDeclaredMethod("run", String.class);
			method.invoke(target, scheduleJob.getParameter());
			
			//任务执行总时长
			long times = System.currentTimeMillis() - startTime;
			log.setTimes((int) times);
			//任务状态    0：成功    1：失败
			log.setStatus(0);
			
			logger.debug("任务执行完毕，任务ID：" + scheduleJob.getId() + "  总共耗时：" + times + "毫秒");
		} catch (Exception e) {
			logger.error("任务执行失败，任务ID：" + scheduleJob.getId(), e);
			
			//任务执行总时长
			long times = System.currentTimeMillis() - startTime;
			log.setTimes((int) times);

			//任务状态    0：成功    1：失败
			log.setStatus(1);
			log.setError(StringUtils.substring(e.toString(), 0, 2000));
		} finally {
			scheduleJobLogService.save(log);
		}
    }
}
